package com.color.admin.system.repository;


import com.color.admin.system.entity.SysDept;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Set;

/**
 * @author HaiQiu
 */
@Repository
public interface DeptRepository extends JpaRepository<SysDept,String>, JpaSpecificationExecutor<SysDept> {

    /**
     * 批量删除部门
     * @param ids 数据ID集合
     * @return 成功条数
     */
    int deleteAllByIdIn(Set<String> ids);

    /**
     * 根据部门名称查询部门
     * @param deptName 部门名称
     * @return 部门
     */
    SysDept findSysDeptByDeptName(String deptName);

    /**
     * 删除部门与用户绑定关联
     * @param deptIds 部门ID集合
     */
    @Modifying
    @Query(value = "delete from sys_users_depts where dept_id in(?1)",nativeQuery = true)
    void deleteUsersByDeptIds(Set<String> deptIds);

    /**
     * 根据父级ID查询部门
     * @param parentIds 父级ID集合
     * @return 部门集合
     */
    List<SysDept> findAllByParentIdIn(Set<String> parentIds);
}
